Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add parameters of Ed25519 and support twisted Edwards curves #317

Open
wants to merge 18 commits into
base: main
Choose a base branch
from

Conversation

querolita
Copy link
Member

This is related to o1-labs/o1js#1283

@querolita querolita changed the title Add parameters of Ed25519 twisted Edwards curve Add parameters of Ed25519 and support twisted Edwards curves Dec 11, 2024
Copy link
Member

@Trivo25 Trivo25 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we remove the .DS_Store file?

@querolita
Copy link
Member Author

Most of the diff is recompiling the bindings to make CI happy

@querolita
Copy link
Member Author

The files that this PR is directly modifying are:
crypto/elliptic-curve-examples.ts
crypto/elliptic-curve.ts
crypto/elliptic-curve.unit-test.ts

Copy link
Member Author

@querolita querolita left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

left some comments for reviewers

name: 'Ed25519',
modulus: exampleFields.f25519.modulus, // 2^255 - 19
order: 0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3edn, //2^252 + 27742317777372353535851937790883648493,
cofactor: 8n,
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is an optional parameter, please a pair of eyes to double check it's correct.


// Twisted Edwards curve tests

const Ed25519 = createCurveTwisted(TwistedCurveParams.Ed25519);
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What's your preferred convention? CurveTwisted or TwistedCurve? Asking because in affine I believe I have read both.

if (z === 0n) {
// degenerate case
return twistedZero;
} else if (z === 1n && g.x === 0n && g.y === 1n) {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If I didn't treat this case separately, the following else if would place a false in the infinity parameter and then unit tests would complain because they used to find assertions of (0,1,false) != (0,1,true). But note that this is a branch that does not exist in the affine counterpart, and it is assuming that the "only" infinity point is exactly (0,1,1).

const Field = createField(p);
const Scalar = createField(order);
const one = { ...generator, infinity: false };
const Endo = undefined; // for Ed25519
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure how to generalize this. When we use this interface for something different than Ed25519, maybe this parameter should change.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants